```
(FILE 'USPAT' ENTERED AT 16:05:59 ON 17 JAN 1999)
           310 S 395/287/CCLS
L2
           372 S 395/280/CCLS
L3
           662 S 395/309/CCLS
L4
           197 S 395/285/CCLS
L5
           271 S 395/306/CCLS
L6
           165 S ISOCHRON? (P) CHANNEL
L7
           548 S LINK? (10A) LIST (P) BUFFER?
L8
            2 S L6 AND L7
L9
             1 S L1 AND L6
L10
             3 S L1 AND L7
L11
             6 S L2 AND L7
L12
             1 S L3 AND L6
L13
             6 S L3 AND L7
L14
             1 S L4 AND L7
L15
            1 S L5 AND L7
         1748 S (TRANSMIT? OR RECEIV?) (P) SOFTWARE (P) ROUTINE
L16
           175 S L16 AND CHANNEL (10A) IDENTIF?
L17
L18
           10 S L7 AND L1
```

```
(FILE 'USPAT' ENTERED AT 16:05:59 ON 17 JAN 1999)
Ll
            310 S 395/287/CCLS
            372 S 395/280/CCLS
L2
            662 S 395/309/CCLS
L3
            197 S 395/285/CCLS
L4
L5
            271 S 395/306/CCLS
L6
            165 S ISOCHRON? (P) CHANNEL
L7
            548 S LINK? (10A) LIST (P) BUFFER?
              2 S L6 AND L7
L8
L9
              1 S L1 AND L6
L10
              3 S L1 AND L7
L11
              6 S L2 AND L7
L12
              1 S L3 AND L6
L13
              6 S L3 AND L7
L14
              1 S L4 AND L7
L15
              1 S L5 AND L7
L16
           1748 S (TRANSMIT? OR RECEIV?) (P) SOFTWARE (P) ROUTINE
L17
            175 S L16 AND CHANNEL (10A) IDENTIF?
L18
             10 S L7 AND L17
                   heady cited
```

=> d 18 1-

1. (5,754,789, May 19, 1998, Apparatus and method for controlling point-to-point interconnect communications between nodes; Andreas G. Nowatzyk, et al., 395/200.63, 182.1, 200.67, 200.68, 200.78 [IMAGE AVAILABLE 1

(5,706,439,)an. 6, 1998, Method and system for matching packet size for efficient transmission over a serial bus; Tony E. Parker, 370/234, 476, 506 [IMAGE AVAILABLE]

=> d 19

1. 5,689,244, Nov. 18, 1997, Communication system and electronic apparatus; Yuko Iijima, et al., 340/825.07; 364/825; 370/357, 360; 395/287 [IMAGE AVAILABLE]

=> d 110 1-

- 1. (5,434,976, Fdl. 18, 1995, Communications controller utilizing an external buffer memory with plural channels between a host and network interface operating independently for transferring packets between protocol layers; Min P. Tan, et al., 395/200.64; 364/228.5, 239, 239.7, DIG.1; 395/200.43, 200.8, 287, 846, 847; 711/1, 149 [IMAGE AVAILABLE]
- 4,933,846, Jun. 12, 1990, Network communications adapter with dual interleaved memory banks servicing multiple processors; Donald J. Humphrey, et al., 395/287; 364/228.1, 229, 230, 230.1, 230.2, 231.4, 238.5, 239, 240, 240.1, 240.5, 240.7, 241.8, 242.3, 242.6, 242.92, 242.94, 242.95, 242.96, 243, 243.6, 246, 246.4, 246.6, 270, 270.4, 271.4, 284, 284.3, 284.4, DIG.1; 370/463 [IMAGE AVAILABLE]
- 4,896,261, Jan. 23, 1990, System for scheduling serial message transmission on a bus which is adoptable for rescheduling prioritized messages using a doubly-linked list; Michael P. Nolan, 395/287; 340/825.5; 364/232.8, 240, 240.1, 242.2, 254, 254.5, 254.6, 260.1, 262,

- 1. 5,832,492, Nov. 3, 1998, Method of scheduling interrupts to the linked lists of transfer descriptors scheduled at intervals on a serial bus; David R. Wooten, 707/101; 395/200.64, 280, 733, 825, 842; 707/100, 102; 711/202 [IMAGE AVAILABLE]
- 2. 5,671,365, Sep. 23, 1997, I/O system for reducing main processor overhead in initiating I/O requests and servicing I/O completion events; Charles D. Binford, et al., 395/280; 364/228.5, 230.2, 244.3, DIG.1; 395/736 [IMAGE AVAILABLE]
- 3. 5,491,808, Feb. 13, 1996, Method for tracking memory allocation in network file server; James F. Geist, Jr., 711/100; 364/280.8, 282.2, 284.2, DIG.1; 395/280, 728; 707/205; 711/200 [IMAGE AVAILABLE]
- 4. 5,448,702, Sep. 5, 1995, Adapters with descriptor queue management capability; Serafin J. E. Garcia, Jr., et al., 395/280, 844, 848 [IMAGE AVAILABLE]
- 5. 4,539,652, Sep. 3, 1985, Networks for data communication; Harvey Rubin, 395/280; 364/919.4, 921.8, 926, 926.9, 926.93, 927.92, 927.97, 927.98, 928, 929.1, 931, 931.01, 931.02, 931.4, 931.43, 932.8, 933.9, 935, 935.2, 939, 939.5, 940, 940.1, 940.2, 940.4, 940.81, 941, 942.3, 942.5, 944.2, 944.5, 948.11, 949.3, 949.91, 949.94, 965, 965.76, 975.1, 976, 976.1, 977, DIG.2 [IMAGE AVAILABLE]
- 6. 4,423,480, Dec. 27, 1983, Buffered peripheral system with priority queue and preparation for signal transfer in overlapped operations; Wayne J. Bauer, et al., 395/280; 364/DIG.1 [IMAGE AVAILABLE]
- => d 112 1-
- 1. 5,815,678, Sep. 29, 1998, Method and apparatus for implementing an application programming interface for a communications bus; Gary Alan Hoffman, et al., 395/309, 828 [IMAGE AVAILABLE]
- => d 113 1-
- 1. 5,828,835, Oct. 27, 1998, High throughput message passing process using latency and reliability classes; Mark S. Isfeld, et al., 395/200.3, 200.62, 200.63, 200.65, 309, 877 [IMAGE AVAILABLE]
- 2. 5,812,800, Sep. 22, 1998, Computer system which includes a local expansion bus and a dedicated real-time bus and including a multimedia memory for increased multi-media performance; Dale E. Gulick, et al., 395/308, 281, 306, 309, 822, 842, 847, 856, 857 [IMAGE AVAILABLE]
- 3. 5,734,848, Mar. 31, 1998, Method and appartus for transferring data in a controller having centralized memory; Dennis E. Gates, et al., 395/308, 309 [IMAGE AVAILABLE]
- 4. 5,729,705, Mar. 17, 1998, Method and apparatus for enhancing throughput of disk array data transfers in a controller; Bret S. Weber, 395/308, 309, 566, 847 [IMAGE AVAILABLE]
- 5. 5,634,015, May 27, 1997, Generic high bandwidth adapter providing data communications between diverse communication networks and computer system; Paul Chang, et al., 395/309; 364/927.92, 927.93, 927.96, 940, 940.61, DIG.2; 370/402, 412 [IMAGE AVAILABLE]

6. (5,452,420, Sep. 19, 95, Intelligent network interior circuit for establishing communication link between protocol machine and host processor employing counter proposal set parameter negotiation scheme; Jonathan R. Engdahl, et al., 395/285; 364/228.1, 240.8, 242.94, DIG.1; 395/309, 891; 711/148 [IMAGE AVAILABLE]

=> d 114 1-

1. 5,452,420, Sep. 19, 1995, Intelligent network interface circuit for establishing communication link between protocol machine and host processor employing counter proposal set parameter negotiation scheme; Jonathan R. Engdahl, et al., 395/285; 364/228.1, 240.8, 242.94, DIG.1; 395/309, 891; 711/148 [IMAGE AVAILABLE]

=> d 115 1-

1. 5,812,800, Sep. 22, 1998, Computer system which includes a local expansion bus and a dedicated real-time bus and including a multimedia memory for increased multi-media performance; Dale E. Gulick, et al., 395/308, 281, 306, 309, 822, 842, 847, 856, 857 [IMAGE AVAILABLE]

=> d 1-

- 1. 5,701,502, Dec. 23, 1997, Isolating a central processing unit from the operating system controlling said unit and its associated hardware for interaction of the unit with data handling apparatus alien to the operating system; Ernest Dysart Baker, et al., 395/500, 200.31, 290, 406, 680 [IMAGE AVAILABLE]
- 2. 5,388,215, Feb. 7, 1995, Uncoupling a central processing unit from its associated hardware for interaction with data handling apparatus alien to the operating system controlling said unit and hardware; Ernest D. Baker, et al., 395/200.59; 364/232.3, 280, DIG.1; 395/200.51, 200.57, 500 [IMAGE AVAILABLE]
- 3. 5,369,767, Nov. 29, 1994, Servicing interrupt requests in a data processing system without using the services of an operating system; John M. Dinwiddie, Jr., et al., 395/737 [IMAGE AVAILABLE]
- 4. 5,369,749, Nov. 29, 1994, Method and apparatus for the direct transfer of information between application programs running on distinct processors without utilizing the services of one or both operating systems; Ernest D. Baker, et al., 395/674; 364/229.1, DIG.1; 395/682, 821 [IMAGE AVAILABLE]
- 5. 5,363,497, Nov. 8, 1994, System for removing section of memory from first system and allocating to second system in a manner indiscernable to both operating systems; Ernest D. Baker, et al., 711/153; 364/228, 245.7, 251.5, DIG.1; 395/200.46 [IMAGE AVAILABLE]
- 6. 5,325,517, Jun. 28, 1994, Fault tolerant data processing system; Ernest D. Baker, et al., 395/182.09 [IMAGE AVAILABLE]
- 7. 5,283,868, Feb. 1, 1994, Providing additional system characteristics to a data processing system through operations of an application program, transparently to the operating system; Ernest D. Baker, et al., 395/200.57; 364/228.7, 228.9, 229, 229.1, 230, 230.3, 232.1, 232.3, 238, 238.4, 239, 240, 240.5, 240.8, 240.9, 241.2, 241.9, 242.3, 242.31, 242.6, 242.94, 242.95, 243, 243.4, 246, 246.3, 247, 247.3, 251, 254, 254.3, 254.5, 256.3, 256.4, 258, 259, 259.2, 264, 265, 268, 268.9, 270, 271, 273.4, 280, 280.2, 280.8, 281.3, 282.1, 282.4, 284, 284.3, DIG.1;

- 8. 5,155,809, Oct. 13, 992, Uncoupling a central processing unit from its associated hardware for interaction with data handling apparatus alien to the operating system controlling said unit and hardware; Ernest D. Baker, et al., 395/200.57, 200.31 [IMAGE AVAILABLE]
- 9. 5,144,692, Sep. 1, 1992, System for controlling access by first system to portion of main memory dedicated exclusively to second system to facilitate input/output processing via first system; Ernest D. Baker, et al., 395/728; 364/228, 228.2, 228.6, 228.7, 228.9, 229, 229.1, 230, 230.2, 230.4, 230.6, 231.8, 232.3, 232.9, 234, 235, 236.2, 238, 238.3, 238.4, 239, 239.7, 240, 240.1, 240.2, 240.8, 240.9, 241.7, 241.9, 242.3, 242.31, 242.6, 242.92, 242.94, 242.95, 243, 243.4, 243.41, 244, 244.3, 244.6, 245.7, 246, 246.3, 246.91, 247, 247.2, 247.5, 247.8, 248.1, 254, 254.5, 255.1, 256.3, 259, 259.1, 259.2, 259.5, 260, 260.1, 260.3, 260.4, 260.8, 261.3, 261.6, 262.4, 262.8, 262.9, 264, 264.6, 265, 265.1, 265.4, 266.5, 268.9, 269.2, 270, 270.3, 271, 271.5, 273.3, 280, 280.2, 280.8, 280.9, 284, 284.4, 285, 927.99, 967, DIG.1; 395/406R, 821; 711/203 [IMAGE AVAILABLE]
- 10. 5,113,522, May 12, 1992, Data processing system with system resource management for itself and for an associated alien processor; John M. Dinwiddie, Jr., et al., 395/553; 364/228, 229, 232.1, 232.3, 234, 235, 236.2, 238, 238.3, 238.4, 239, 240, 240.8, 241.9, 242.94, 243, 243.4, 243.41, 244.6, 247, 252, 254, 254.5, 258, 259, 259.1, 259.2, 265, 268, 268.9, 271.5, 280, 280.2, 280.6, 282.1, 282.3, 284, DIG.1; 395/182.08,

US PAT NO:

5,754,789 [IMAGE AVAILABLE]

L8: 1 of 2

SUMMARY:

BSUM (22)

These . . . being inserted when no other information is being transferred. The delay time in transmission is adjusted by a temporal alignment buffer in the channel modules to ensure that an integral multiple of packet transmission times are used for the total delay. . arrival and start of each packet transmission. The four channel modules on a single interconnect controller chip share a common buffer pool with linked list entries for identifying which channel module is to propagate each received packet. The common buffer pool is segmented into sixteen (16) bit segments so that received packets may begin retransmission before completing arrival. This also. . .

DETDESC:

**DETD (27)** 

When a channel module attempts to write received data into the packet buffer pool, the 12-bit address is simultaneously supplied to the routing table circuitry 29. The routing table circuitry outputs an 8-bit word that specifies which virtual channel may be used for the packet. This word is interpreted by the buffer control logic 41. The buffer control logic 41 maintains a linked list index to the registers of the packet buffer pool. Various registers may be free or occupied at different times irrespective of their actual location in the register file. The linked list index provides head-to-tail linked list pointers for all stored data packets and is used to index the packet buffer pool 40. By using the multi-ported register file that is accessible by all channels, each channel module may deposit received. . .

CLAIMS:

CLMS(1)

We . . .

communications channels and a plurality of adjacent nodes to each of which the node is coupled through a single communications channel, respectively, each of said nodes having an interconnect controller having means for controlling the exchange of data packets having a length of (W) bits over communications channel, wherein to transmit a packet having (W) bits plus (X) appended control bits requires a time (T), the method of. . .

packets stored in said common buffer pool of a node for transmission to an adjacent node through an appropriate communications **channel** where said selection of said appropriate communications **channel** is determined by indexing a destination id included in said data packet into a routing table;

assigning data packets in said routing table to **channel** modules having the fewest pending transactions;

extracting a data packet from said common buffer pool for transmission through said selected communications channel;

determining check code bits for said data packet based on the content of said data packet;

appending said data macket with said check code bits rand continuously convey? It a packets between adjacent through isochronous coupled communications channels by convert a data packet upon receiving a data packet.

## CLAIMS:

CLMS(2)

- data packets including packet age identification bits incremented to indicate the occurrence of certain conditions including delivery failure:
- a plurality of channel modules each coupled to one of said plurality of communications ports, respectively, for controlling the flow of said data packets into and out of said interconnect controller wherein each of said channel modules may be coupled to a channel module of an adjacent node through interconnect controllers implemented in said adjacent nodes, said coupled channel modules of two adjacent nodes continuously exchanging a flow of data packets through an isochronous communications channel;
- timing control logic means incorporated in each of said plurality of channel modules for adjusting the round trip delay (Dij) of packets exchanged between coupled adjacent channel modules to equal an integral number of T transmission times where Dij is the round trip time for a data. . . register having a variable depth which is set to adjust the round trip delay (Dij) for packets exchanged between adjacent channel modules to be an integral multiple of packet transmission time (T);
- a clock means and means for synchronizing said clock means. interconnect controller with the clock means of said adjacent interconnect controller:
- a common buffer pool coupled to said plurality of channel modules for buffering incoming and outgoing data packets; and routing table logic in communication with said common buffer pool and said plurality of channel modules for routing data packets through appropriate channel modules.

## CLAIMS:

## CLMS(6)

packets are deleted if said packet age identification bits indicate packet age to be beyond a predetermined value;

- a plurality of channel modules each coupled to one of said plurality of communications ports, respectively, for controlling the flow of said data packets into and out of said interconnect controller wherein each of said channel modules may be coupled to a channel module of an adjacent node through interconnect controllers implemented in said adjacent nodes, said coupled channel modules of two adjacent nodes continuously exchanging a flow of data packets through an isochronous communications channel;
- timing control logic means incorporated in each of said plurality of channel modules for adjusting the round trip delay (Dij) of packets exchanged between coupled adjacent channel modules to equal an integral number of T transmission times where Dij is the round trip time for a data. . . a node i to a node j and back to node i; a common buffer pool coupled to said plurality of channel modules for buffering incoming and outgoing data packets; and routing table logic in communication with said common buffer pool and said plurality of channel modules for routing data packets through